Namespaces
Variants

std::literals::chrono_literals:: operator""ns

From cppreference.net
Definiert im Header <chrono>
constexpr std:: chrono :: nanoseconds
operator "" ns ( unsigned long long nsec ) ;
(1) (seit C++14)
constexpr std:: chrono :: duration < /*unspecified*/ , std:: nano >
operator "" ns ( long double nsec ) ;
(2) (seit C++14)

Bildet ein std::chrono::duration Literal, das Nanosekunden repräsentiert.

1) Integer-Literal, gibt exakt std:: chrono :: nanoseconds ( nsec ) zurück.
2) Fließkommaliteral, gibt eine Fließkomma-Dauer zurück, die äquivalent zu std::chrono::nanoseconds ist.

Inhaltsverzeichnis

Parameter

nsec - die Anzahl der Nanosekunden

Rückgabewert

Das std::chrono::duration Literal.

Mögliche Implementierung

constexpr std::chrono::nanoseconds operator""ns(unsigned long long ns)
{
    return std::chrono::nanoseconds(ns);
}
constexpr std::chrono::duration<long double, std::nano> operator""ns(long double ns)
{
    return std::chrono::duration<long double, std::nano>(ns);
}
**Hinweis:** Der Code innerhalb der `
`-Tags wurde gemäß den Anforderungen nicht übersetzt, da er C++-Code enthält. Die HTML-Struktur und Attribute bleiben ebenfalls unverändert.

Hinweise

Dieser Operator ist im Namensraum std :: literals :: chrono_literals deklariert, wobei sowohl literals als auch chrono_literals Inline-Namensräume sind. Der Zugriff auf diesen Operator kann erfolgen durch:

  • using namespace std :: literals ,
  • using namespace std :: chrono_literals , oder
  • using namespace std :: literals :: chrono_literals .

Zusätzlich wird innerhalb des Namespace std :: chrono die Direktive using namespace literals :: chrono_literals ; von der Standardbibliothek bereitgestellt, sodass wenn ein Programmierer using namespace std :: chrono ; verwendet, um Zugriff auf die Klassen in der Chrono-Bibliothek zu erhalten, die entsprechenden Literaloperatoren ebenfalls sichtbar werden.

Beispiel

#include <chrono>
#include <iostream>
int main()
{
    using namespace std::chrono_literals;
    auto d1{250ns};
    std::chrono::nanoseconds d2{1us};
    std::cout << d1 << " = " << d1.count() << " nanoseconds\n"
              << d2 << " = " << d2.count() << " nanoseconds\n";
}

Ausgabe:

250ns = 250 nanoseconds
1000ns = 1000 nanoseconds

Siehe auch

Konstruiert neue Duration
(öffentliche Elementfunktion von std::chrono::duration<Rep,Period> )